<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>

        *{
            margin: 0;
            padding: 0;
        }

        div{
            position: absolute;
            left: 50%;
            top:50%;
        }

       #out{
          width: 400px;
          height: 400px;
          background-color: blue;  
          margin-top: -200px;
          margin-left: -200px;
       }

       #middle{
           width: 200px;
           height: 200px;
           background-color: chartreuse;
           margin-top: -100px;
           margin-left: -100px;
       }

       #inner{
           width: 100px;
           height: 100px;
           background-color: violet;
           margin-top: -50px;
           margin-left: -50px;
       }


    </style>
</head>
<body>

      <div id='out'>
          <div id='middle'>
              <div id='inner'></div>
          </div>
      </div>
    
</body>
</html>

<script>

  /*
   事件流：也可以理解的为事件的传播。

    事件分为两种 ： 1 冒泡流  -->  从最确定的到最不确定的。
                   2 捕获流  -->  它于冒泡流相反 是从最不确定的到最确定的。

  */
let outDiv = document.getElementById('out');
let middleDiv = document.getElementById('middle');
let innerDiv = document.getElementById('inner');

innerDiv.onclick=()=>{
    alert('inner');
}
middleDiv.onclick=()=>{
    alert('middleDiv');
}


outDiv.onclick=()=>{
    alert('outDiv');
}

</script>